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PROGRAMMABLE SERIAL INTERFACE 



Field of the Invention 

The present invention relates to a method and/or 
architecture for point-to-point communication devices generally 
and, more particularly, to a programmable serial interface. 

Background of the Invention 

Point-to-point and point -to -multipoint communication 
devices allow for a transfer of data signals over high-speed serial 
links. Each transmit channel of the communication devices receives 
parallel data signals at an input, converts the parallel data 
signal to a serial data signal and transmits the serial data signal 
to a receiving channel . Each receiving channel of the 
communication devices receives the serial data signal from a 
transmit channel, converts the serial data signal back into the 
parallel data signal and presents the parallel data signal. 

Pre- transmission processing and post -reception processing 
of the parallel data signals are conventionally performed outside 
the communication device in additional circuitry. Examples of 
processing performed by the additional circuitry include 



0325.00485 
CD01026 

f raming/de - framing , header insertion/removal , error 
encoding/detection and byte stuffing/de-stuffing. The presence of 
the additional circuitry consumes space, power and cost while 
decreasing reliability . 

One approach to improve the space, power and reliability 
factors is designing an application specific communication device 
with built-in pre- transmission processing and the post-reception 
signal processing. Disadvantages of the application specific 
approaches include increased design costs and fixed signal 
processing functionality. What is desired is a low-cost 
communication device where the signal processing is programmable to 
adapt to a wide variety of applications. 

Summary of the Invention 

The present invention concerns a programmable serial 
interface device. The device generally comprises a programmable 
logic device and another die mounted to an assembly apparatus. The 
programmable logic device may comprise (i) a plurality of logic 
block clusters and (ii) a plurality of routing channels configured 
to interconnect said logic block clusters. The die may comprise a 
first communication channel (i) configured to convert between a 
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first serial data signal and a first parallel data signal and (ii)- 
coupled to a first of the routing channels to exchange the first 
parallel data signal with at least one of the logic block clusters. 



invention include providing a method and architecture for a 
communication device that may be (i) low cost, (ii) programmable, 
(iii) high speed and/or (iv) a single package device. 

Brief Description of the Drawings 

These and other objects, features and advantages of the 
present invention will be apparent from the following detailed 
description and the appended claims and drawings in which: 



The objects, features and advantages of the present 



FIG. 1 is a block diagram of a device implementing the 



present invent ion ; 



FIG. 2 is a detailed block diagram of a complex 



programmable logic device ; 



FIG. 3 is a detailed block diagram of a communication 



die; and 



FIG. 4 is a flow diagram of a method of fabricating the 



device . 
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Detailed Description of the Preferred Embodiments 

Referring to FIG. 1, a block diagram of a device 100 is 
shown in accordance with a preferred embodiment of the present 
invention. The device 100 generally comprises a circuit (or die) 
102 and a circuit (or die) 104 mounted on an assembly apparatus 
105. The circuit 102 may be implemented as a programmable die and 
the circuit 104 may be implemented as a serial communication die. 
For example, the circuit 102 may be implemented as a logic device, 
a complex programmable logic device (CPLD) , a field programmable 
gate array, or the like. The circuit 104 may be implemented as a 
point-to-point communication device, a point- to-multipoint 
communication device, a serial transceiver, or the like. For the 
purposes of illustrating the present invention, the circuit 102 may 
hereinafter be referred to as a CPLD 102. The circuit 104 may 
hereinafter be referred to as a serialization/deserialization 
circuit or SERDES 104 for short. The assembly apparatus 105 may be 
implemented as a ceramic substrate, a metal or plastic housing, or 
the like. 

The CPLD 102 may have an interface 106 to exchange one or 
more signals (e.g., IN and OUT) with an interface 108 of the SERDES 
104. The CPLD 102 may have an additional interface 110 to exchange 
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signals (e.g., CNTR, RESP and DATA) externally to the device 100. 
The SERDES 104 may have an interface 112 to exchange one or more 
signals (e.g., TX and RX) externally to the device 100. 

The signal IN may comprise multiple signals (e.g., AIN, 
BIN, CIN and DIN) , one for each communication channel of the SERDES 
104. The signal OUT may comprise multiple signals (e.g., AOUT, 
BOUT, COUT and DOUT) , one for each communication channel of the 
SERDES 104. The signal TX may comprise multiple signals (e.g., 
TXA, TXB, TXC and TXD) , one for each communication channel of the 
SERDES 104. The signal RX may comprise multiple signals (e.g., 
RXA, RXB, RXC and RXD) , one for each communication channel of the 
SERDES 104. The signal DATA may comprise one or more individual 
data signals flowing into and from the CPLD 102. The signal CNTR 
may comprise one or more individual control signals received by the 
CPLD 102. The signal RESP may comprise one or more response 
signals presented by the CPLD 102 . 

The CPLD 102 may receive the signal DATA and signal CNTR 
prior to transmission. The CPLD 102 may perform pre- transmission 
processing of the signal DATA in accordance with the signal CNTR to 
produce the signal OUT. The CPLD 102 may present the signal OUT to 
the SERDES 104. The SERDES 104 may convert the signal OUT from a 
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parallel format into the signal TX having a serial format. The 

SERDES 104 may then transmit the signal TX. 

The SERDES 104 may receive the signal RX at the start of 

reception. The SERDES 104 may convert the signal RX from the 
5 serial format into the signal IN having the parallel format. The 

SERDES 104 may then present the signal IN to the CPLD 102. The 

CPLD 102 may perform post-reception processing on the signals IN to 
3 produce at least one of the signal DATA and the signal RESP. The 
^ CPLD 102 may then present the signal DATA and/or the signal RESP 
10%j externally to the device 100. 

m 

O Programming of the device 100 may be performed by any 

conventional method suitable for the particular implementation of 
the CPLD 102 and the SERDES 104, if programmable. The programming 
y» may be performed during a one-time download process or repeatedly 
15 during each power-up, depending upon the capabilities of the CPLD 
102 and the SERDES 104. Programming of the CPLD 102 may define the 
pre- transmission processing and/or the post-reception processing. 
Programming examples for the SERDES 104 may include, but are not 
limited to, set-up parameter initialization, encoding/decoding 
2 0 selection, baud rate, parity generate/check, input clocking 
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options, output clocking options, skew alignment, serial signaling 
rate and multi -communication channel bonding options. 

The.CPLD 102 may comprise multiple logic block clusters 
114 (designated as "CL" ) , multiple routing channels 116 and 

5 multiple I/O banks 118. ' The logic block clusters 114 may be 
arranged in a one or two dimensional array. The routing channels 
116 may be disposed between horizontally and/or vertically adjacent 

q logic block clusters 114. The I/O banks 118 may be disposed around 
the outer edge of the CPLD 102. Each of the I/O banks 118 may be 

Q 

1(F coupled to one or more of the routing channels 116. 



The routing channels 116 may be dynamically configured to 



p transfer signals among the logic block clusters 114 and the I/O 
H* banks 118. For example, the routing channels 116 may convey 

u 

jf3 signals between a particular I/O bank 118 and one or more of the 
15 logic block clusters 114. In another example, the routing channels 
116 may convey signals among individual logic block clusters 114. 
The signals may be carried from a source to a destination or 
multiple destinations by a single routing channel 116 or multiple 
routing channels 116. The routing channels 116 generally move the 
20 signals in the parallel format, although the signals may be moved 
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in the serial format to meet the design criteria of a particular 
application. 

The signal processing may be performed by the logic block 
clusters 114. One or more logic block clusters 114 may be 
5 programmed to operate on one or more signals IN, OUT, DATA, CNTR 
and/or RESP. The individual logic block clusters 114 may operate 
independently from each other and/or in cooperation with each other 
^ depending upon the programming. Examples of pre -transmission 
q processing may include, but are not limited to, header insertion, 
byte stuffing, forward error code generation, framing, code 

UT 

O piercing, convolution encoding, encryption, data to symbol 



N 

3 . 



yy 



conversion and block staggering. Examples of post -reception 
processing may include, but are not limited to, header removal, 
byte de-stuffing, error detection, error correction, de-framing, 
15 pierced code insertion, convolution decoding, decryption, symbol to 
data conversion and block reorganizing. 

Each of the logic block clusters 114 may comprise 
multiple logic blocks, a programmable interconnect matrix, a 
channel memory block and multiple cluster memory blocks (not 
2 0 shown) . Each of the logic blocks may comprise basic programmable 
logic functions such as product term arrays, product term 
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allocators and macrocells (not shown) . The cluster memory blocks 
and the channel memory blocks may each comprise any mixture of 
volatile and non-volatile memory. Other configurations within the 
CPLD 102 may be implemented to meet the design criteria of a 
particular application. 

Referring to FIG. 2, a detailed block diagram of an 
example circuit implementing the CPLD 102 is shown. Each of the 
I/O banks 118 generally comprises two or one and a half I/O blocks 
120. The FIG. 2 shows an example having fourteen I/O blocks 120 
within eight I/O banks 118. Each of the I/O blocks 120 may be 
associated with one of the routing channels 116. A combination of 
two half I/O blocks (e.g., 120A and 120B) may also be associated 
with one of the routing channels 116. Other configurations of I/O 
blocks 120 within the I/O banks 118 may be implemented to meet the 
design criteria of a particular application. 

Each of the I/O blocks 120, including the half I/O blocks 
120, may comprise multiple I/O cells (not shown) . Generally, there 
may be one I/O cell for each bit transferred by the associated 
routing channel 116. Each of the I/O cells may be programmable to 
receive or present the bit synchronously or asynchronously. 
Multiple I/O cells may be operated together to exchange the signals 
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CNTR, RESP, DATA, IN and OUT with the parallel format. Individual 
I/O cells may be programmed to exchange other signals having a one 
bit width. 

Referring to FIG. 3, a detailed block diagram of an 
example circuit implementing the SERDES 104 is shown. The SERDES 
104 generally comprises one or more channels 122. In one example, 
the SERDES 104 may have four channels 122A-D. Each channel 122 may 
comprise a transmit communication channel 124 and/or a receive 
communication channel 126. 

10^1 The transmit communication channel 124 may receive a 

in 

Q signal (e.g., TXDn[7:0], where n identifies the channel A-D) . The 
transmit communication channel 124 may receive another signal 
(e.g., TXCTn[l:0], where n identifies the channel A-D). The 
jp[ combination of the signal TXDn[7:0] and the signal TXCTn[l:0] may 
15 form the signal nOUT, where n identifies the channel A-D. 

The signal TXDn[7:0] may be implemented as a data signal 
having a parallel format and conveying information to be 
transmitted. The signal TXCTn[l:0] may be implemented as a control 
signal. The signal TXCTn[l:0] may identify how the signal 
2 0 TXDn[7:0] characters are to be interpreted. In one example, the 
signal TXCTn[l:0] may be an encoding selection signal that may 
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indicate that the signal TXDn[7:0] is to be encoded as data or a 
special character code. In another example, the signal TXCTn[l:0] 
may disable data encoding and in turn may contain two additional 
bits of the data signal to be transmitted. 

The transmit communication channel 124 may present a 
signal (e.g., OUTnl, where n identifies the channel A-D) . The 
transmit communication channel 124 may present another signal 
(e.g., OUTn2, where n identifies the channel A-D) . One or both of 
the signals OUTnl or OUTn2 may be presented as the signal TXn, 
where n identifies the channel A-D. The signal TXn may have a 
serial format . 

The transmit communication channel 124 may comprise a 
circuit 128, a circuit 130, a circuit 132 and a circuit 134. The 
circuit 128 may be implemented as a phase align buffer. The 
circuit 13 0 may be implemented as an encoder. The circuit 132 may 
be implemented as a serializer. The circuit 134 may be implemented 
as a dual differential line driver. 

The phase align buffer 12 8 may provide synchronization 
between the signals TXDn[7:0] and TXCTn[l:0] and a clock signal 
(e.g., REFCLK) . The encoder 130 may provide for 8B/10B encoding of 
the signal TXDn[7:0]. The serializer 132 may convert the encoded 



0325.00485 
CD01026 

data signal from the parallel format to the serial format. The 
line driver 134 may present the serial data signal as the signals 
OUTnl and OUTn2 . 

The receive communication channel 12 6 may receive a 
signal (e.g., INnl, where n identifies the channel A-D) . The 
receive communication channel 126 may receive another signal (e.g., 
INn2, where n identifies the channel A-D). One or both of the 
signals INnl or INn2 may form the signal RX. The signal RX may 
have a serial format . 

The receive communication channel 126 may present a 
signal (e.g., RXDn[7:0], where n identifies the channel A-D) . The 
receive communication channel 126 may present another signal (e.g., 
RXSTn[2:0], where n identifies the channel A-D). The combination 
of the signals RXDn[7:0] and RXSTn[2:0] may form the signal nIN, 
where n identifies the channel A-D. The signal RXDn[7:0] may be 
implemented as a data signal having the parallel format and 
conveying the information received. The signal RXSTn[2:0] may be 
implemented as a status signal. In one example, the signal 
RXSTn[2:0] may indicate decoding of the signal RXDn[7:0] as the 
data signal or the special character code. In another example, the 
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signal RXSTn[2:0] may transfer two bits of the data signal when the 
decoding is disabled. 

The receive communication channel 12 6 may comprise a 
circuit 136, a circuit 138, a circuit 140, a circuit 142 and a 
circuit 144. The circuit 136 may be implemented as a dual 
differential line receiver. The circuit 138 may be implemented as 
a deserializer. The circuit 140 may be implemented as a framer. 
The circuit 142 may be implemented as a decoder. The circuit 144 
may be implemented as an elasticity buffer. 

The line receiver 13 6 may receive the signals INnl and 
INn2 . The deserializer 138 may convert the received signals from 
the serial format to the parallel format. The framer 140 may 
detect boundaries of a frame of data and extract the data signal . 
The decoder 142 may perform 8B/10B decoding of the extracted data 
signal. The elasticity buffer 144 may provide for buffering of the 
data signal, status signal and any error detection bits between an 
output of the decoder 142 and the presentation of the signals 
RXDn[7:0] and RXSTn[2:0], where n identifies the channel A-D. 

Referring to FIG. 4, a flow diagram of a method of 
fabricating the device 100 is shown. The process may begin by 
providing the CPLD 102, the SERDES 104, the assembly apparatus 105 

13 



0325.00485 
CD01026 

and any other die and/or components (e.g., a lid, bonding wire, 
capacitors, resistors and such) to be used during the assembly 
(e.g., block 146). The CPLD 102, SERDES 104 and the other 
components may then be mounted on the assembly apparatus 105 (e.g. , 
5 block 148). Connections may be created between the CPLD 102, 
SERDES 104, assembly apparatus 105 and the other components (e.g., 
block 150) . The connections may include coupling the 

a 

communications channels 124 and 126 of the SERDES 104 with the 
O routing channels 116 of the CPLD 102. The coupling between 
10^ communication channels 124 and 126 and routing channels 116 may 

Q 

^ have a one-to-one relationship. Each communication channel 124 and 

O 

126 may be coupled through an I/O block 120 to one routing channel 
W 116. 

9 

H 2 

After the connections have been made, the device 100 may 
15 be tested (e.g., block 152) . If the device 100 passes the testing 
step, then a cover may be attached to seal the device thus forming 
a completed package (e.g., block 154) . In an alternative process, 
the cover may be attached prior to testing. Additional steps may 
be performed on the device 100 after attaching the cover to meet 
20 the criteria of a particular fabrication and test process. 
Optionally, the device 100 may then be programmed to meet the 
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requirements of a particular application specified by a customer. 
Alternatively, the device 100 may be supplied to the customer 
unprogrammed . 

The various signals of the present invention may be 
implemented as single-bit or multi-bit signals in a serial and/or 
parallel configuration. 

While the invention has been particularly shown and 
described with reference to the preferred embodiments thereof, it 
will be understood by those skilled in the art that various changes 



lCKi in form and details may be made without departing from the spirit 

m 

^ and scope of the invention. 
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